# Corso Sistemi Operativi

#### Prof. Pierfrancesco Bellini

pierfrancesco.bellini@unifi.it Laboratorio DISIT Dip. Ingegneria dell'Informazione Via S. Marta, 3

1

# Programma A.A. 2021/22

#### Introduzione

- Struttura di un calcolatore, gestione I/O ed interruzioni
- Introduzione ai sistemi operativi
- Struttura dei sistemi operativi

#### Le basi del linguaggio Java

#### Gestione dei processi

- I processi
- I thread
- Scheduling della CPU
- Sincronizzazione tra processi
- Gestione dello stallo

#### Gestione della memoria

- Gestione della memoria centrale
- Memoria virtuale



Sistemi Operativi A.A 2021/2022 2

## Libri di testo principali

A. Silberschaz, P. Galvin, G. Gagne,

#### Sistemi Operativi: Concetti ed esempi,

decima edizione, Pearson Addison-Wesley.

G. Bucci,

#### Calcolatori elettronici, Architettura e organizzazione

2017, McGraw-Hill

K. Arnold, J. Gosling, D. Holmes

#### Java manuale ufficiale,

Pearson Addison-Wesley

Altro materiale su:

http://www.disit.org/sistemi-operativi



Sistemi Operativi A.A 2021/2022

3

### Esame

- Corso da 6 CFU
- Corso integrato con Calcolatori elettronici, per poter verbalizzare l'esame il modulo di calcolatori deve essere stato sostenuto

#### Esame Scritto

- Uno scritto sufficiente è valido fino al corso successivo
- Scritto composto da:
  - un esercizio su scheduling cpu o gestione stallo
  - un esercizio programmazione java sincronizzazione thread
- Entro tre giorni dopo lo scritto deve essere consegnata versione funzionante del secondo esercizio dello scritto
- Uno scritto di fine corso nei primi giorni di giugno oltre al primo appello
- Un eventuale appello straordinario a fine novembre

#### Esame Orale

- Discussione dello scritto dove presentate implementazione
- Due domande su teoria



Sistemi Operativi A.A 2021/2022 4

# Gestione Input/Output e Interruzioni

5

## Architettura del calcolatore

- Componenti del calcolatore
  - CPU
  - Memoria
  - Periferiche I/O
    - Tastiera, schermo, dischi rigidi, USB, etc
  - **Bus** (Dati, Indirizzi, Controllo)



Sistemi Operativi A.A 2021/2022 6



# Interfaccia dispositivo I/O

- Intermediario tra dispositivo e bus
- Dispositivi e CPU procedono in modo asincrono ognuno alla propria velocità.
- L'interfaccia deve fornire:
  - registri di appoggio per i dati da inviare/ricevere
  - registri per i comandi alla periferica
  - tenere traccia dello stato dela periferica ed eventuali errori
- L'interfaccia espone dei registri (o pseudo-registri)
  - DREG per lo scambio dei dati
  - CREG per i comandi alla periferica
  - SREG per leggere lo stato della periferica



Sistemi Onesathi A A 2021 (2022 S

## Input/output

- La CPU per accedere ai registri delle interfacce può usare
  - I/O mappato in memoria
  - I/O isolato
  - entrambi

#### I/O mappato in memoria:

- una parte della memoria riservata per la comunicazione con i dispositivi
- es. memoria video

#### I/O isolato

- istruzioni specifiche usate per interazione con dispositivi tramite porte di input/output
- porte identificate da un numero (indirizzo)
- spazio di indirizzamento distinto da quello della memoria



Sistemi Operativi A.A 2021/2022

9

## I/O isolato

#### Istruzioni dedicate a input/output

- la cui esecuzione hanno cicli di bus del tutto analoghi a quelli di accesso alla memoria solo che vengono usate due linee di comando specifiche
  - IORC (I/O Read Command)
  - IOWC (I/O Write Command)
- Processore x86
  - IN AL, PORT
    - presenta **PORT** sul bus indirizzi
    - asserisce IORC
    - Iegge dal bus dati e mette in AL
  - OUT PORT, AL
    - presenta **PORT** sul bus indirizzi
    - presenta sul bus dati il contenuto di AL

asserisce il comando **IOWC** 

Sistemi Operativi A.A 2021/2022 10





## PC IBM e Porte I/O

I «vecchi» PC IBM hanno una serie di porte ben definite per I/O

| Port range    | Summary                                                                                                   |
|---------------|-----------------------------------------------------------------------------------------------------------|
| 0x0000-0x001F | The first legacy DMA controller, often used for transfers to floppies.                                    |
| 0x0020-0x0021 | The first Programmable Interrupt Controller                                                               |
| 0x0022-0x0023 | Access to the Model-Specific Registers of Cyrix processors.                                               |
| 0x0040-0x0047 | The PIT (Programmable Interval Timer)                                                                     |
| 0x0060-0x0064 | The "8042" PS/2 Controller or its predecessors, dealing with keyboards and mice.                          |
| 0x0070-0x0071 | The CMOS and RTC registers                                                                                |
| 0x0080-0x008F | The DMA (Page registers)                                                                                  |
| 0x0092        | The location of the fast A20 gate register                                                                |
| 0x00A0-0x00A1 | The second PIC                                                                                            |
| 0x00C0-0x00DF | The second DMA controller, often used for soundblasters                                                   |
| 0x00E9        | Home of the Port E9 Hack. Used on some emulators to directly send text to the hosts' console.             |
| 0x0170-0x0177 | The secondary ATA harddisk controller.                                                                    |
| 0x01F0-0x01F7 | The primary ATA harddisk controller.                                                                      |
| 0x0278-0x027A | Parallel port                                                                                             |
| 0x02F8-0x02FF | Second serial port                                                                                        |
| 0x03B0-0x03DF | The range used for the IBM VGA, its direct predecessors, as well as any modern video card in legacy mode. |
| 0x03F0-0x03F7 | Floppy disk controller                                                                                    |
| 0x03F8-0x03FF | First serial port                                                                                         |

13

## Porte dell'interfaccia

- porta di ingresso (dalla periferica)
  - buffer con uscita in terzo stato, uscita abilitata quando asserito IORC (istruzione IN)
- porta di uscita (verso la periferica)
  - latch per memorizzare il dato, acquisizione effettuata quando viene asserito IOWC (istruzione OUT)



## Modalità esecuzione I/O

- nessuna sincronizzazione tra programma in esecuzione e periferiche (molto più lente)
- la CPU deve aspettare...
- le tecniche fondamentali per la gestione delle periferiche sono:
  - Legestione a controllo di programma
  - II. sotto controllo di interruzione
  - III. tramite accesso diretto alla memoria o con processori I/O



Sistemi Operativi A.A 2021/2022 15

15

# Controllo di programma

- Consideriamo una interfaccia di uscita verso una stampante
- è necessario un protocollo di hand-shacking con la stampante
  - DAV (Data AVailable) indica che il dato è disponibile
  - DAC (Data ACkowledge) indica che il dato è stato acquisito ed un nuovo dato può essere inviato.





Sottoprogramma di gestione

- sottoprogramma STAMPA si aspetta:
  - nel registro SI l'offset del buffer da stampare
  - nel registro CX il numero di byte da stampare
- uso:

MOV SI, <offset BUFFER>

MOV CX, <n>

CALL STAMPA

implementazione:

STAMPA: MOV AL, [SI]

OUT E1h, AL

ATTESA: IN AL, E1h

AND AL, 1
JNZ ATTESA

INC SI

LOOP STAMPA

RET

Sistemi Operativi A.A 2021/20

CPU attende il DAC=0 dalla stampante

Tempo CPU sprecato!

18

UNIVERSITÀ DINFO DISIT FIRENZE

## Gestione sotto controllo di interruzione

- Durante l'attesa del DAC la CPU è bloccata, in realtà potrebbe fare altro ed essere interrotta quando il DAC viene asserito dalla stampante.
- All'interruzione viene eseguita una routine di servizio (interrupt handler) che invierà l'eventuale nuovo dato alla stampante e la CPU riprenderà esecuzione da dove era stata interrotta.
- L'esecuzione della routine avviene tra l'esecuzione di due istruzioni



19

# Modello semplificato sistema interruzione

- Si ipotizza che il sistema piloti una sola periferica
- la linea INTR in ingresso alla CPU indica una richiesta di interruzione
- esiste un flag nella CPU che indica abilitazione delle interruzioni IE (Interrupt Enable)
- Al termine della esecuzione di una istruzione la CPU controlla se è arrivata una interruzione IINTR, in questo caso la CPU deve azzerare IE (in modo che non possa essere interrotta) e fare fetch dell'istruzione all'indirizzo 0 (senza modificare PC)
- L'istruzione all'indirizzo 0 dovrà essere una CALL alla procedura di gestione degli interrupt
- La procedura terminerà con istruzione IRET che abiliterà anche interruzioni



UNIVERSITÀ DINFO DISIT

Setomi Onombisi & A 2021 (2022 20



## Routine di servizio

- L'esecuzione della routine di servizio dell'interrupt deve essere trasparente rispetto al programma interrotto
- alla posizione 0 viene inserita istruzione CALL alla routine gestione interruzione
- la routine deve:
  - 1. salvare sullo stack PSW (parola di stato) e tutti i registri usati
  - 2. trasferire il prossimo dato
  - 3. disasserire la richiesta di interruzione
  - 4. ripristinare registri
  - 5. ritornare al programma interrotto
- per il punto 5 c'è istruzione IRET che è come RET solo che abilita le interruzioni



Sistemi Onemski A A 2021 (2022) 22

## Routine di servizio

Stesso uso:

MOV SI, <offset BUFFER>

MOV CX, <n>
CALL STAMPA

...

Sezione di inizializzazione:

STAMPA: MOV BUSY,1

MOV IND, SI MOV COUNT, CX

MOV AL, [SI]
OUT DPORT, AL

MOV AL, 1

OUT CPORT, AL

RET

Sistemi Operativi A A 2021/2022 23

23

## Routine di servizio

Routine di servizio interruzione: ESCI: POP SI INTSTAMP: PUSH PSW  $\mathsf{CX}$ POP PUSH AX POP ΑX PUSH  $\mathsf{CX}$ POP **PSW** PUSH SI **IRET** MOV SI, IND FINE: MOV BUSY,0 INC SI MOV AL,0 MOV CX, COUNT CPORT,AL OUT DEC  $\mathsf{CX}$ JMP **ESCI** JΖ **FINE** MOV AL, [SI] OUT **DPORT, AL** MOVIND, SI COUNT, CX MOV UNIVERSITÀ DINFO DISIT

#### 2 STAMPE

Che succede se il programma chiama due volte STAMPA?

MOV SI, MSG1 CX, 10 MOV STAMPA CALL

MOV SI, MSG2 CX, 5 MOV CALL STAMPA

- Se la stampa precedente era terminata, OK
- Ma se la stampa precedente non era terminata...
- Si può aggiungere a STAMPA prima di impostare a 1 BUSY

WAIT: MOV AL, BUSY JNZ WAIT

Per controllare che non sia in corso una stampa, ma comporta una attesa attiva... si potrebbe evitare?



25

# Interruzione da parte di più periferiche

- Si hanno i seguenti problemi:
  - riconoscere la periferica dal quale arriva l'interruzione
  - scegliere quale è la routine di servizio da esequire
  - gestione priorità, si possono avere richieste contemporanee, si deve stabilire quale ha priorità maggiore
  - gestire l'interrompibilità della routine di servizio da parte di periferica a priorità maggiore





Interruzioni vettorizzate inefficienza superata: • il dispositivo indica il numero di interrupt (IRQ i) • la CPU esegue direttamente la routine associata usando tabella TABIR (contenente le procedure di gestione) • Il numero della interrupt viene acquisito tramite un ciclo di bus il segnale INTA indica che la CPU ha ricevuto interruzione e attende su bus dati il numero IRQ TABIR CALL ROUTINE 0 INTE CALL ROUTINE 1 CALL ROUTINE 2 CALL ROUTINE i CALL ROUTINE n-1













## Accesso diretto alla memoria

- Per dispositivi che leggono/scrivono tanti dati velocemente (es. dischi rigidi, schede di rete) trasferire tutti i singoli byte usando le interruzioni sarebbe molto inefficiente
- La CPU può delegare questa attività al **DMAC** (Direct Memory Access Controller)



35

## **DMA**

#### Operazioni

- 1. Interfaccia richiede servizio DMA (DMREQ)
- 2. DMAC richiede alla CPU uso del bus (BUSREQ)
- 3. CPU concede bus al DMAC (BUSACK) fintanto che BUSREQ è asserito
- 4. DMAC mette indirizzo su bus indirizzi, attiva MR e IOW o MW e IOR
- 5. La periferica scrive/legge su bus dati il dato da trasferire
- 6. Finito il trasferimento DMAC disattiva BUSREQ e CPU acquisisce nuovamente BUS e disattiva BUSACK



## Struttura DMA

- L'architettura del DMA prevede:
  - un contatore del numero di caratteri/parole da trasferire
  - un puntatore alla posizione dove andrà scritto/letto il dato in memoria
  - un registro di comando con il tipo di trasferimento
  - un eventuale registro di stato
- Fase di programmazione
  - visto come dispositivo dotato di un insieme di registri
- Trasferimento dati con due modalità
  - trasferimento singolo, trasferisce un singolo carattere
  - **trasferimento a blocchi**, trasferisce tutte le parole indicate dal contatore, incrementando o decrementando la posizione, occupa il BUS fino alla terminazione del trasferimento,
    - al termine del trasferimento viene generata interruzione



Sistemi Operativi A.A 2021/2022 37

37





## Interruzioni

- **asincrone**: generate dai dispositivi I/O
- **sincrone**: generate dall'esecuzione delle istruzioni
  - dovute ad errori che avvengono nell'esecuzione di una istruzione (dette in questo caso anche eccezioni)
  - dovute ad una chiamata esplicita con una istruzione specifica es. "INT 21h", simile a chiamata a procedura, chiama la procedura associata a una posizione della tabella delle interruzioni
- Molto importanti per i sistemi operativi



Sistemi One antici & & 2021 (2022) 40